<template>
  <div>
    <Card>
        <Form ref="searchForm" @keydown.enter.native.prevent="handleSearch" :model="searchForm"  class="search-form">
          <Form-item label="会员名称"  class="flex" prop="memberName">
            <Input
              type="text" placeholder="请输入会员名称" v-model="searchForm.memberName" clearable
              style="width: 240px"></Input>
          </Form-item>
          <Form-item label="编号" class="flex">
            <Input
              type="text" placeholder="请输入编号" v-model="searchForm.sn" clearable
              style="width: 240px"></Input>
          </Form-item>
          <Form-item label="状态"
                     style="width: 240px">
            <Select v-model="searchForm.distributionCashStatus" clearable style="width: 150px">
                <Option v-for="item in cashStatusList" :value="item.value" :key="item.value">{{ item.label }}</Option>
            </Select>
          </Form-item>
          <Form-item>
            <Button @click="handleSearch" type="primary">搜索</Button>
          </Form-item>
        </Form>
        </Card>
    <Card>
      <Table :loading="loading" border :columns="columns" :data="data" ref="table" class="mt_10"></Table>
      <Row type="flex" justify="end" class="page padding-row">
        <Page :current="searchForm.pageNumber" :total="total" :page-size="searchForm.pageSize" @on-change="changePage" @on-page-size-change="changePageSize" :page-size-opts="[10,20,50]" size="small" show-total show-elevator show-sizer></Page>
      </Row>
    </Card>
    <Modal :title="modalTitle" v-model="modalVisible" :mask-closable='false' :width="500">
      <Form ref="form" :model="form" :label-width="100"  >
      <FormItem label="编号">
          <Input disabled v-model="form.sn" clearable style="width:100%"/>
        </FormItem>
        <FormItem label="会员名称">
          <Input disabled v-model="form.distributionName" clearable style="width:100%"/>
        </FormItem>
        <FormItem label="金额">
          <Input disabled v-model="form.price" clearable style="width:100%"/>
        </FormItem>
        <FormItem label="是否通过" prop="result" v-if="handleStatus =='edit'">
             <RadioGroup v-model="result" type="button" button-style="solid">
                 <Radio label="VIA_AUDITING">通过</Radio>
                 <Radio label="FAIL_AUDITING">拒绝</Radio>
             </RadioGroup>
        </FormItem>
      </Form>
      <div slot="footer" v-if="handleStatus == 'edit'">
        <Button type="text" @click="modalVisible=false">取消</Button>
        <Button type="primary" :loading="submitLoading" @click="handleSubmit">提交</Button>
      </div>
    </Modal>
  </div>
</template>

<script>
import {
auditDistributionCash,
getDistributionCash
} from "@/api/distribution";
import { cashStatusList } from './dataJson';
export default {
  name: "distributionCash",
  data() {
    return {
      cashStatusList, // 状态列表
      loading: true, // 表单加载状态
      modalVisible: false, // 添加或编辑显示
      modalTitle: "", // 添加或编辑标题
      result: 'FAIL_AUDITING', // 是否通过
      searchForm: { // 搜索框初始化对象
        pageNumber: 1, // 当前页数
        pageSize: 10, // 页面大小
        sort: "createTime", // 默认排序字段
        order: "desc", // 默认排序方式
      },
      handleStatus:'edit',// 判断是编辑还是查看
      form: { // 添加或编辑表单对象初始化数据
        sn: "",
        memberName: "",
        price: "",
      },
      submitLoading: false, // 添加或编辑提交状态
      columns: [
        {
          title: "编号",
          key: "sn",
          minWidth: 200
        },
        {
          title: "会员名称",
          key: "distributionName",
          minWidth: 120
        },
        {
          title: "申请金额",
          key: "price",
          minWidth: 90,
          render: (h, params) => {
            return h("priceColorScheme", {props:{value:params.row.price,color:this.$mainColor}} );
          },
        },
        {
          title: "申请时间",
          key: "createTime",
          minWidth: 130
        },
        {
          title: "姓名",
          key: "name",
          minWidth: 100,
        },
        {
          title: "身份证号",
          key: "idNumber",
          minWidth: 120,
        },
        {
          title: "结算银行开户行名称",
          key: "settlementBankAccountName",
          minWidth: 120,
        },
        {
          title: "结算银行开户账号",
          key: "settlementBankAccountNum",
          minWidth: 120,
        },
        {
          title: "结算银行开户支行名称",
          key: "settlementBankBranchName",
          minWidth: 120,
        },
        {
          title: "处理时间",
          key: "updateTime",
          minWidth: 130
        },
        {
          title: "状态",
          key: "distributionCashStatus",
          minWidth: 100,
          render: (h, params) => {
              if (params.row.distributionCashStatus == 'APPLY') {
                   return h("div", "待处理");
              }
              if (params.row.distributionCashStatus == 'VIA_AUDITING') {
                   return h("div", "通过");
              }
              if (params.row.distributionCashStatus == 'FAIL_AUDITING') {
                   return h("div", "审核拒绝");
              }
            },
         },
        {
          title: "操作",
          key: "action",
          align: "center",
          fixed: "right",
          width: 130,
          render: (h, params) => {
            if(params.row.distributionCashStatus != 'APPLY'){
                return h("div", [
                  h(
                    "Button",
                    {
                      props: {
                        type: "primary",
                        size: "small",
                      },
                      style: {
                        marginRight: "5px"
                      },
                      on: {
                        click: () => {
                          this.view(params.row);
                        }
                      }
                    },
                    "查看"
                  ),

                ]);
            }else {
                return h("div", [
                  h(
                    "Button",
                    {
                      props: {
                        type: "primary",
                        size: "small",
                      },
                      style: {
                        marginRight: "5px"
                      },
                      on: {
                        click: () => {
                          this.edit(params.row);
                        }
                      }
                    },
                    "审核"
                  ),

                ]);
            }
          }
        }
      ],
      data: [], // 表单数据
      total: 0 // 表单数据总数
    };
  },
  methods: {
    // 初始化数据
    init() {
      this.getDataList();
    },
    // 改变页码
    changePage(v) {
      this.searchForm.pageNumber = v;
      this.getDataList();
    },
    // 改变页数
    changePageSize(v) {
      this.searchForm.pageSize = v;
      this.getDataList();
    },
    // 搜索
    handleSearch() {
      this.searchForm.pageNumber = 1;
      this.searchForm.pageSize = 10;
      this.getDataList();
    },
    // 获取列表数据
    getDataList() {
      this.loading = true;
      // 带多条件搜索参数获取表单数据 请自行修改接口
      getDistributionCash(this.searchForm).then(res => {
        this.loading = false;
        if (res.success) {
          this.data = res.result.records;
          this.total = res.result.total;
        }
      });
      this.total = this.data.length;
      this.loading = false;
    },
    // 通过还是拒绝申请
    handleSubmit() {
      let result = "拒绝"
      if(this.result == 'VIA_AUDITING'){
        result = "通过"
      }
      this.$refs.form.validate(valid => {
        if (valid) {
          this.$Modal.confirm({
            title: "确认审核",
            content: "您确认要审核"+result+"么?",
            loading: true,
            onOk: () => {
                auditDistributionCash(this.form.id,{result:this.result}).then(res => {
                    if (res.success) {
                      this.$Modal.remove();
                      this.$Message.success("审核成功");
                      this.getDataList();
                      this.modalVisible = false;
                    } else {
                      this.modalVisible = false;
                    }
                });
            }
          })
        }
      });
    },
    // 弹出modal 审核
    edit(v) {
      this.modalTitle = "审核";
      this.handleStatus = 'edit';
      this.$refs.form.resetFields();
      // 转换null为""
      for (let attr in v) {
        if (v[attr] === null) {
          v[attr] = "";
        }
      }
      this.form = JSON.parse(JSON.stringify(v));
      this.modalVisible = true;
    },
    // 弹出modal 查看
    view(v){
      this.modalTitle = "查看";
      this.handleStatus = 'view';
      this.$refs.form.resetFields();
      // 转换null为""
      for (let attr in v) {
        if (v[attr] === null) {
          v[attr] = "";
        }
      }
      let str = JSON.stringify(v);
      let data = JSON.parse(str);
      this.form = data;
      this.modalVisible = true;

    }
  },
  mounted() {
    this.init();
  }
};
</script>
